<template>
  <div class="">
    <UploadExal :on-success="success" />
  </div>
</template>

<script>
import { importEmployee } from '@/api/employees'
export default {
  name: 'Import',
  components: {},
  props: {},
  data() {
    return {}
  },
  computed: {}, // 计算属性
  watch: {},
  created() {},
  mounted() {},
  methods: {
    async  success({ header, results }) {
      // header 中的数据 是中文 results 中的数据也是中文
      // 新增的员工的属性是一致的
      // username: '',姓名
      // mobile: '', 手机号
      // formOfEmployment: '',
      // workNumber: '', 工号
      // departmentName: '',
      // timeOfEntry: '', 入职日期
      // correctionTime: '' 转正日期
      const userRelations = {
        入职日期: 'timeOfEntry',
        手机号: 'mobile',
        姓名: 'username',
        转正日期: 'correctionTime',
        工号: 'workNumber'
      }
      // var arr = []
      // results.forEach((item) => {
      //   var userInfo = {}
      //   Object.keys(item).forEach((key) => {
      //     // 现在key是中文
      //     userInfo[userRelations[key]] = item[key] // 将原来中文对应的值 赋值给原来英文对应的值
      //   })
      //   arr.push(userInfo)
      // })

      var newArr = results.map(item => {
        var userInfo = {}
        Object.keys(item).forEach(key => {
          if (userRelations[key] === 'timeOfEntry' || userRelations[key] === 'correctionTime') {
            // 后端结构 限制了 不能是字符串 要求转化成时间类型
            userInfo[userRelations[key]] = this.formatDate(item[key])
          }
          userInfo[userRelations[key]] = item[key]
        })
        return userInfo
      })
      await importEmployee(newArr) // 接受一个数组
      this.$message.success('导入excel成功')
      this.$router.back() // 跳到上一个页面
    },
    // 转化excel的日期格式
    formatDate(numb, format) {
      const time = new Date((numb - 1) * 24 * 3600000 + 1)
      time.setYear(time.getFullYear() - 70)
      const year = time.getFullYear() + ''
      const month = time.getMonth() + 1 + ''
      const date = time.getDate() - 1 + ''
      if (format && format.length === 1) {
        return year + format + month + format + date
      }
      return year + (month < 10 ? '0' + month : month) + (date < 10 ? '0' + date : date)
    }
  }
}
</script>

<style scoped></style>
